<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" %>
<%@ include file="../include/laypublic.jsp" %>
<%@ include file="../include/vueComponent.jsp" %>
<!DOCTYPE html>
<html>
<head>
    <title>质押合同详情</title>
</head>
<link rel="stylesheet" href="${ctx}/resources/vue-element-lib/detail.css">

<body>
<div id="app">
    <div class="layui-tab layui-tab-brief" lay-filter="xqxx-tab-all">
        <ul class="layui-tab-title">
            <li id="tbglId" class="layui-this" lay-id="0">
                质押合同详情
            </li>
            <%--            <li id="zgysId" lay-id="1">历史审批信息</li>--%>
        </ul>
        <div class="layui-tab-right">
            <c:if test="${isAuditFlag eq '1'}">
            <template v-if="layId==0">
                <button type="button" class="layui-btn layui-btn-primary layui-btn-radius" @click="save(0)">保存
                </button>
                <button type="button" class="layui-btn layui-btn-radius" @click="save(1)">提交</button>
            </template>
            </c:if>
            <c:if test="${auditTabFlag eq '1'}">
                <button type="button" class="layui-btn layui-btn-primary layui-btn-radius" @click="audit(0)">
                    不同意
                </button>
                <button type="button" class="layui-btn layui-btn-radius" @click="audit(1)">同意</button>
            </c:if>
        </div>

        <div class="layui-tab-content" style="height: 100px;">
            <div class="layui-tab-item layui-show">
                <div class="container">
                    <el-form ref="formRef" label-width="180px" label-suffix="："
                             label-position="left">
                        <div class="title">
                            <h3>融资基础信息</h3>
                        </div>
                        <el-row>
                            <x-col>
                                <el-form-item label="融资业务名称">
                                    <span v-if="id">{{info.proName}}</span>
                                    <el-select v-model="info.proCode" @change="selProCode" style="width: 100%" v-else>
                                        <el-option v-for="item in financingNames" :label="item.proName"
                                                   :key="item.proCode" :value="item.proCode"></el-option>
                                    </el-select>
                                </el-form-item>
                            </x-col>
                            <x-col position="right">
                                <el-form-item label="融资业务编码">
                                    <span>{{info.proCode}}</span>
                                </el-form-item>
                            </x-col>
                        </el-row>
                        <el-row>
                            <x-col>
                                <el-form-item label="合同编号">
                                    <span>{{info.codes}}</span>
                                </el-form-item>
                            </x-col>
                            <x-col position="right">
                                <el-form-item label="被担保单位">
                                    <span>{{info.compName}}</span>
                                </el-form-item>
                            </x-col>
                        </el-row>
                        <el-row>
                            <x-col>
                                <el-form-item label="金融机构">
                                    <el-select v-model="info.setupFinancialId" style="width: 100%">
                                        <el-option v-for="item in institutions" :label="item.dockBank"
                                                   :key="item.id" :value="item.id"></el-option>
                                    </el-select>
                                </el-form-item>
                            </x-col>
                            <x-col position="right">
                                <el-form-item label="质押价值">
                                    <span>{{num}}</span>
                                </el-form-item>
                            </x-col>
                        </el-row>
                        <div class="title">
                            <h3>质押物信息</h3>
                        </div>
                        <div class="unit">
                            <div class="unit_add">
                                <button class="layui-btn layuiadmin-btn-admin" type="button" data-type="add"
                                        @click="add">
                                    <i class="layui-icon layui-icon-add-1 layuiadmin-button-btn"></i>添加质押物
                                </button>
                            </div>
                            <div class="unit_center">
                                <div class="unit_img">
                                    <div class="item" v-for="(item,index) in details" :key="index"
                                         v-if="details.length>1">
                                        <img src="${ctx}/resources/images/del.png" alt="" @click="del(index)">
                                    </div>
                                </div>

                                <el-table :data="details" style="width: 100%" border>
                                    <el-table-column prop="pledgeComp" label="质押物所属单位" align="center" width="200">
                                        <template slot-scope="scope">
                                            <el-select v-model="scope.row.pledgeComp" filterable placeholder="请选择">
                                                <el-option v-for="item in pledgeComp" :key="item.id"
                                                           :label="item.compName" :value="item.id"></el-option>
                                            </el-select>
                                        </template>
                                    </el-table-column>
                                    <el-table-column prop="pledgeName" label="质押物名称" align="center" width="200">
                                        <template slot-scope="scope">
                                            <x-input name="质押物名称" v-model="scope.row.pledgeName"></x-input>
                                        </template>
                                    </el-table-column>
                                    <el-table-column prop="pledgeNo" label="质押物证号" align="center" width="200">
                                        <template slot-scope="scope">
                                            <x-input name="质押物证号" v-model="scope.row.pledgeNo"></x-input>
                                        </template>
                                    </el-table-column>
                                    <el-table-column prop="pledgeNumber" label="质押比例或份数" align="center" width="200">
                                        <template slot-scope="scope">
                                            <x-input name="质押比例或份数" v-model="scope.row.pledgeNumber"></x-input>
                                        </template>
                                    </el-table-column>
                                    <el-table-column prop="pledgeAmount" label="质押价值(万元)" align="center" width="200">
                                        <template slot-scope="scope">
                                            <x-input name="质押价值" v-model="scope.row.pledgeAmount"
                                                     @input="sum"></x-input>
                                        </template>
                                    </el-table-column>
                                    <el-table-column prop="applicantName" label="登记单位" align="center" width="200">
                                        <template slot-scope="scope">
                                            <x-input name="登记单位" v-model="scope.row.applicantName"></x-input>
                                        </template>
                                    </el-table-column>
                                    <el-table-column prop="agent" label="经办人" align="center" width="200">
                                        <template slot-scope="scope">
                                            <x-input name="经办人" v-model="scope.row.agent"></x-input>
                                        </template>
                                    </el-table-column>
                                    <el-table-column prop="agentDate" label="经办日期" align="center" width="200">
                                        <template slot-scope="scope">
                                            <el-date-picker style="width: 100%" v-model="scope.row.agentDate"
                                                            type="date" placeholder="选择经办日期"
                                                            value-format="yyyy-MM-dd"></el-date-picker>
                                        </template>
                                    </el-table-column>
                                </el-table>
                            </div>
                        </div>
                        <div class="title">
                            <h3>合同说明</h3>
                        </div>
                        <el-row>
                            <x-col position="full">
                                <el-form-item label="说明">
                                    <x-input v-model="info.contractSpecification" type="textarea" :rows="4"
                                             name="其他"></x-input>
                                </el-form-item>
                            </x-col>
                        </el-row>
                        <div class="title">
                            <h3>项目附件信息</h3>
                        </div>
                        <div class="layui-form-item">
                            <label class="layui-form-label" style="width:350px;">支持pdf、excel、word、图片资料，可上传多个</label>
                        </div>
                        <div class="layui-form-item">
                            <label class="layui-form-label">附件</label>
                            <div class="layui-input-block">
                                <div class="layui-upload">
                                    <button type="button" class="layui-btn" type="button" id="50-upload-more">上传
                                    </button>
                                    <div class="layui-upload-list" id="50-upload-more-list">
                                    </div>
                                </div>
                            </div>
                        </div>

                        <c:if test="${auditTabFlag eq '1'}">
                            <div class="title">
                                <h3>审批信息</h3>
                            </div>
                            <%@ include file="process/process-audit.jsp" %>
                        </c:if>
                    </el-form>
                </div>
            </div>
            <div class="layui-tab-item">
                <%--                <%@ include file="process/process-history.jsp" %>--%>
            </div>
        </div>
    </div>
</div>
<script src="${ctx}/resources/vue-element-lib/jquery.js"></script>
<script>
    var fileArr = [];
    var staticPath = '${fileHttpPre}';
    layui.config({
        base: '${ctx}/resources/layuiadmin/' //静态资源所在路径
    }).extend({
        index: 'lib/index' //主入口模块
    }).use(['index', 'set', 'upload', 'table', 'transfer', 'laydate', 'element', 'layer'], function () {
        var $ = layui.$
            , upload = layui.upload
            , table = layui.table
            , element = layui.element
            , layer = layui.layer;

        //选项卡切换监听
        element.on('tab(xqxx-tab-all)', function (data) {
            var layId = $(this).attr('lay-id');
            vm.$data.layId = layId;
            if (layId === "0") {

            } else if (layId === "1") {
                loadTable(layId);
            }
        });

        function loadTable(layId) {
            // 表单
            table.render({
                elem: '#lay-lsspxx-create-manage'
                , url: basePath + '/historyProcess/list?proCode=${proCode}'
                , cols: [[
                    {
                        field: 'startTime', title: '发起时间', width: 145, width: 155, templet: function (d) {
                            return layui.util.toDateString(d.startTime, "yyyy-MM-dd HH:mm:ss");
                        }
                    }
                    , {field: 'startRealName', title: '发起人', width: 145}
                    , {field: 'proFlowType', title: '审批阶段', width: 145}
                    , {field: 'proFlowNode', title: '审批节点', width: 145}
                    , {
                        field: 'dealTime', title: '审批日期', width: 155, templet: function (d) {
                            return layui.util.toDateString(d.dealTime, "yyyy-MM-dd HH:mm:ss");
                        }
                    }
                    , {field: 'dealName', title: '审批人', width: 160}
                    , {field: 'state', title: '审批状态'}
                    , {
                        title: '操作', width: 140, align: 'center', fixed: 'right', templet: function (d) {
                            var optStr = "";
                            optStr += '<a class="layui-btn layui-btn-xs" lay-event="view"><i class="layui-icon layui-icon-form"></i>查看</a>';
                            return optStr;
                        }
                    }
                ]]
                , page: true
                , limit: 10
            });

            // 监听操作列
            table.on('tool(lay-lsspxx-create-manage)', function (obj) {
                var data = obj.data;
                if (obj.event === 'view') {//查看
                    parent.layui.index.openTabsPage(basePath + '/historyProcess/toDetail?processId=' + data.processId, '历史流程信息 > 详情');
                }
            });
        }

        //多文件列表示例
        ;(function () {
            //定义构造函数
            var Upfile = function (ele, type, opt) {
                this.defaults = {
                    //elem:‘#uploadPic‘	//绑定元素
                    elem: $(ele)	//绑定元素
                    , url: basePath + '/contractInfo/uploadAtt/',
                    data: {
                        types: type
                    },
                    multiple: true,
                    accept: 'file',
                    acceptMime: 'application/zip,application/x-rar-compressed,image/jpeg,image/png,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document,application/vnd.ms-powerpoint,application/vnd.openxmlformats-officedocument.presentationml.presentation,application/vnd.ms-excel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,application/pdf',

                    method: 'post',
                    before: function (obj) { //obj参数包含的信息
                        layer.load(); //上传loading
                    },
                    done: function (res) {
                        //如果上传失败
                        if (res.code > 0) {
                            layer.closeAll('loading'); //关闭loading
                            return layer.msg(res.msg, {icon: 7});
                        }
                        //上传完毕
                        if (res.entity != null && res.entity.length > 0) {
                            fileArr.push(res.entity[0])
                            for (var i in res.entity) {
                                var contractInfo = res.entity[i];
                                var arr = contractInfo.split("|");
                                var imgSrc = "";
                                var suffix = arr[1].substring(arr[1].lastIndexOf(".") + 1, arr[1].length);
                                if (suffix == 'jpg' || suffix == 'png') {
                                    imgSrc = "${fileHttpPre}/" + arr[3];
                                } else {
                                    imgSrc = "${ctx}/resources/images/" + suffix + ".jpg";
                                }
                                $('#' + type + '-upload-more-list')
                                    .append('<div class="layui-upload-img-div" id="upload_img_' + arr[2] + '"><img src="' + imgSrc + '" title="'
                                        + arr[1] + '" class="layui-upload-img"><div class="mask"><a href="javascript:void(0)" onclick="showImg(\'' + "${fileHttpPre}"
                                        + arr[3] + '\');">查看</a><a href="javascript:void(0)" onclick="del(\''
                                        + arr[2] + '\')";>删除</a></div><p>' + arr[1] + '</p><input type="hidden" value="'
                                        + contractInfo + '" id="fileAtt_' + arr[2] + '" name="fileAtts" ></input></div> ');
                            }
                        }
                    },
                    allDone: function (obj) { //当文件全部被提交后，才触发
                        layer.closeAll('loading'); //关闭loading
                    },
                    error: function () {
                        layer.closeAll('loading'); //关闭loading
                        //上传失败
                        layer.msg("上传失败，请稍后再试~", {icon: 7});
                    }
                }
                this.options = $.extend({}, this.defaults, opt);
            };

            //定义方法
            Upfile.prototype = {
                init: function () {
                    var _this = this;
                    return layui.use('upload', function () {
                        var upload = layui.upload;

                        //执行实例
                        var uploadInst = upload.render(_this.options);
                    });
                }
            };

            //在插件中使用对象
            $.fn.upfile = function (options) {
                var upfile = new Upfile(this, options);
                return upfile.init();
            }
        })();
        //上传文件
        $('#50-upload-more').upfile(50);
    });

    //删除文件
    function del(index) {
        layui.$("#fileAtt_" + index).remove();
        layui.$("#upload_img_" + index).remove();
        fileArr.map((el, idx) => {
            if (el.split('|')[2] == index) {
                fileArr.splice(idx, 1)
            }
        })
    }

    //根据url查看文件
    function showImg(url) {
        var openWin = window.open(url, '', 'left=410,height=768, width=1024, top=200,  toolbar=no, menubar=no, scrollbars=no, resizable=no,location=no, status=no');
    }

    /*核心*/
    var vm = new Vue({
        el: '#app',
        data() {
            return {
                layId: '0',
                procNodeList: [],
                tempNodeList: [],
                auditMsg: '',//审批意见
                processId: '',

                info: {
                    proName: '',
                    proCode: '',
                },
                num: '',
                details: [],
                institutions: [],
                financingNames: [],
                pledgeComp: [],
            }
        },
        created() {
            this.id = "${id}";
            this.queryDetail();
            this.processId = "${processId}";
            this.queryProcessList();
        },
        mounted() {

        },
        methods: {
            selProCode(e) {
                this.financingNames.map(el => {
                    if (el.proCode == e) {
                        this.info = el;
                    }
                })
                this.queryListInstitutions(e)
            },
            queryListInstitutions(e) {
                let that = this;
                $.ajax({
                    type: 'post',
                    url: basePath + '/financingPlan/queryListInstitutions',  //请求数据接口
                    data: {proCode: e},
                    success: function (result) {
                        if (result.entity) {
                            that.institutions = result.entity;
                        }
                    }
                });
            },
            sum() {
                let sum = 0;
                this.details.map(el => {
                    sum += Number(el.pledgeAmount)
                })
                this.num = Number(sum) > 0 ? Number(sum).toFixed(2) : 0
            },
            queryDetail() {
                let that = this;
                $.ajax({
                    type: 'post',
                    url: basePath + '/contractPledge/queryDetail',  //请求数据接口
                    data: {id: that.id},
                    success: function (result) {
                        if (result.entity) {
                            if (result.entity.info) that.info = result.entity.info;
                            that.pledgeComp = result.entity.pledgeComp;
                            that.details = result.entity.details ? result.entity.details : [];
                            that.financingNames = result.entity.financingNames;
                            if (that.details.length > 0) that.sum();
                            if (that.id) that.institutions = result.entity.institutions;
                            showFile(result.entity.fileAtt);
                        }
                    }
                });
            },
            add() {
                let obj = {
                    pledgeComp: '',// 质押物所属单位
                    pledgeName: '',// 质押物名称
                    pledgeNo: '',// 质押物证号
                    pledgeNumber: '',// 质押比例或份数
                    pledgeAmount: '',//质押价值
                    applicantName: '',//登记单位
                    agent: '',//经办人
                    agentDate: '',//经办日期
                }
                this.details.push(obj)
            },
            del(index) {
                this.details.splice(index, 1)
            },
            error(text) {
                this.$message({
                    message: text,
                    type: 'warning'
                });
            },

            save(type) {
                let that = this;
                if (!that.info.contractSpecification) return that.error('请输入或选择合同说明');
                if (this.details.length == 0) return that.error('请添加担保单位信息')
                for (let i = 0; i < this.details.length > 0; i++) {
                    if (!this.details[i].pledgeComp) return that.error('请选择质押物所属单位');
                    if (!this.details[i].pledgeName) return that.error('请输入质押物名称');
                    if (!this.details[i].pledgeNo) return that.error('请输入质押物证号');
                    if (!this.details[i].pledgeNumber) return that.error('请输入质押比例或份数');
                    if (!this.details[i].pledgeAmount) return that.error('请输入质押价值');
                    if (!this.details[i].applicantName) return that.error('请输入登记单位');
                    if (!this.details[i].agent) return that.error('请输入经办人');
                    if (!this.details[i].agentDate) return that.error('请选择经办日期');
                }
                that.info.sum = that.num;
                let obj = {
                    info: that.info,
                    details: that.details,
                    fileAtt: fileArr,
                };
                let str = JSON.stringify(obj).replace(/\"/g, '\\"');
                $.ajax({
                    type: 'post',
                    url: basePath + '/contractPledge/edit',  //请求数据接口
                    async: false,
                    data: {
                        bodyStr: str,
                        submitType: type,
                    },
                    success: function (result) {
                        if (result.success) {
                            that.$message({
                                message: '保存成功',
                                type: 'success'
                            });
                            setTimeout(function () {
                                // 刷新首页
                                let index = window.parent.layui.admin.tabsPage.index
                                if (index == null) {
                                    window.close();
                                } else {
                                    var iframe = window.parent.layui.admin.tabsBody((index - 1)).find(".layadmin-iframe");
                                    iframe[0].contentWindow.location.reload();
                                    top.layui.admin.closeThisTabs(); // 关闭当前标签页
                                }
                            }, 3000);
                        } else {
                            that.$message.error(result.msg);
                        }
                    }
                });
            },
            queryProcessList() {
                let that = this;
                $.ajax({
                    type: 'post',
                    url: basePath + '/capHistoryProcess/processList',  //请求数据接口
                    data: {processId: that.processId},
                    success: function (result) {
                        if (result.success) {
                            that.procNodeList = result.entity.procNodeList;
                            that.tempNodeList = result.entity.tempNodeList;
                        }
                    }
                });
            },
            audit(status) {
                let that = this;

                $.ajax({
                    type: 'post',
                    url: basePath + '/submitApproval/auditProcess',  //请求数据接口
                    async: false,
                    data: {
                        id: that.id,
                        processId: that.processId,
                        status: status,
                        auditMsg: that.auditMsg,
                    },
                    success: function (result) {
                        if (result.success) {
                            that.$message({
                                message: '操作成功',
                                type: 'success'
                            });
                            setTimeout(function () {
                                // 刷新首页
                                let index = window.parent.layui.admin.tabsPage.index
                                if (index == null) {
                                    window.close();
                                } else {
                                    var iframe = window.parent.layui.admin.tabsBody((index - 1)).find(".layadmin-iframe");
                                    iframe[0].contentWindow.location.reload();
                                    top.layui.admin.closeThisTabs(); // 关闭当前标签页
                                }
                            }, 3000);
                        } else {
                            that.$message.error('保存失败');
                        }
                    }
                });
            }
        }
    })
</script>
</body>
</html>

